@import (reference) "rb/css/defs.less";
@import (reference) "rb/css/mixins/theme.less";
@import (reference) "rb/css/ui/colors.less";
@import (reference) "rb/css/ui/responsive.less";


@img_base: '../../images';


#rb-ns-pages() {
  .base() {
    /** The max screen width allowed for mobile mode. */
    @mobile-mode-max-screen-width: 800px;

    /**
     * Apply rules when the UI shell is in desktop mode.
     *
     * This should not be used exclusively for responsive UIs. Rather, it
     * should be used to apply styles related to the mode of the UI shell
     * (the top bar, navigation, sidebar, etc.).
     *
     * What constitutes desktop mode may change in time.
     *
     * Args:
     *     @rules (ruleset):
     *         The rules to apply when the shell is in desktop mode.
     *
     *     @else (ruleset, optional):
     *         Optional rules to apply when the shell is not in desktop mode.
     */
    .on-shell-desktop-mode(@rules, @else: null) {
      @_mobile-mode-width: #rb-ns-pages.base[@mobile-mode-max-screen-width];

      #rb-ns-ui.screen.on-width-gt(@_mobile-mode-width, @rules, @else);
    }

    /**
     * Apply rules when the UI shell is in mobile mode.
     *
     * This should not be used exclusively for responsive UIs. Rather, it
     * should be used to apply styles related to the mode of the UI shell
     * (the top bar, navigation, sidebar, etc.).
     *
     * What constitutes mobile mode may change in time.
     *
     * Args:
     *     @rules (ruleset):
     *         The rules to apply when the shell is in mobile mode.
     *
     *     @else (ruleset, optional):
     *         Optional rules to apply when the shell is not in mobile mode.
     */
    .on-shell-mobile-mode(@rules, @else: null) {
      @_mobile-mode-width: #rb-ns-pages.base[@mobile-mode-max-screen-width];

      #rb-ns-ui.screen.on-width-lte(@_mobile-mode-width, @rules, @else);
    }

    /**
     * Apply rules for when the UI shell is displaying full-page content.
     *
     * Full-page content mode is when the content area is positioned so that
     * it's always fully on-screen, taking up the full height of the viewport,
     * generally with its own content area handling scrolling. Callers can
     * use this to add new rules that apply in this mode.
     *
     * Args:
     *     @rules (ruleset):
     *         The rules to apply when in full-page content mode.
     */
    .on-full-page-content-mode(@rules) {
      body {
        &.full-page-content,  /* Deprecated */
        &.-is-content-full-page {
          @rules();
        }
      }
    }

    /**
     * Set the content are to be flush with the edges of the UI shell.
     *
     * This will remove the padding on the page container and the margin
     * between the top bar and the container.
     */
    .set-content-flush() {
      #page-container {
        padding: 0;
      }

      #topbar {
        margin-bottom: 0;
      }
    }
  }
}


/**
 * The main body element for the page.
 *
 * Modifiers:
 *     -has-sidebar:
 *         Whether the page has a sidebar shown.
 *
 *     -is-content-flush:
 *         Removes any margins and padding between the page content and the
 *         UI shell.
 *
 *     -is-content-flush-on-desktop:
 *         Removes any margins and padding between the page content and the
 *         UI shell when in desktop mode.
 *
 *     -is-content-flush-on-mobile:
 *         Removes any margins and padding between the page content and the
 *         UI shell when in mobile mode.
 *
 *     -is-content-full-page:
 *         Whether the content area should take up the full visual width
 *         and height of the page container. This keeps the content within
 *         the viewport, and allows the content to take care of its own
 *         scrolling.
 */
body {
  @_page-sidebar-mobile-menu-vars: #rb-ns-ui.page-sidebar.mobile-menu();

  background-color: #rb-ns-ui.colors[@grey-90];
  color: @default-text-color;
  font-family: @font-family;
  font-size: 11px;
  margin: 0;
  padding: 0;

  &.-is-content-flush {
    #rb-ns-pages.base.set-content-flush();
  }

  #rb-ns-pages.base.on-shell-mobile-mode({
    background: #rb-ns-ui.colors[@white];

    &.js-mobile-menu-open {
      /*
       * When opening the mobile sidebar menu, lock the viewport so the user
       * can't scroll, and shift everything on the page over by the menu's
       * width. This will animate them, using the transitions set on the
       * elements.
       */
      .no-page-scroll();

      #container {
        transform: translate(@_page-sidebar-mobile-menu-vars[@width], 0);
        height: 100%;
      }
    }

    /*
     * If the page indicates it's showing a sidebar, and the UI shell is in
     * mobile mode, override the content placement so it's not offset by the
     * size of the sidebar.
     */
    &.-has-sidebar {
      #content {
        margin-left: 0;
      }
    }

    &.-is-content-flush-on-mobile {
      #rb-ns-pages.base.set-content-flush();
    }
  }, @else: {
    &.-has-sidebar {
      .rb-c-page-sidebar {
        display: block;
      }

      #page-container {
        padding-left: 0;
      }
    }

    &.js-rb-c-drawer-is-shown {
      #page-sidebar-main-pane {
        opacity: 0;
      }
    }

    &.-is-content-flush-on-desktop {
      #rb-ns-pages.base.set-content-flush();
    }

    .rb-c-page-sidebar {
      display: none;
    }
  });
}

html {
  scroll-behavior: smooth;
}

#rb-ns-pages.base.on-full-page-content-mode({
  /*
   * Set the page to not scroll and have all content take up the maximum
   * height.
   */
  .no-page-scroll();

  /*
   * Set the content to take up the full height of #page-container. It's
   * expected that RB.PageView will size #page-container appropriately for
   * the page.
   */
  #container,
  #content_container,
  #content {
    height: 100%;
    margin-bottom: 0;
    vertical-align: top;
  }

  #rb-ns-pages.base.on-shell-desktop-mode({
    /*
     * Set the page sidebar's panes container and all panes to allocate
     * the full height of #page-sidebar, so that #page-sidebar's scrolling
     * will be allowed to kick in. It's expected that RB.PageView will size
     * #page-sidebar appropriately for the page.
     */
    #page-sidebar-panes,
    .rb-c-page-sidebar__pane {
      height: 100%;
    }
  });

  /*
   * Hide both the page sidebar panes and page container by default, so we
   * can display them initially at the correct height.
   */
  #page-container,
  #page-sidebar-main-pane {
    display: none;
  }
});


/*
 * Set the mobile widths on some components.
 */
@_mobile-mode-max-width: #rb-ns-pages.base[@mobile-mode-max-screen-width];

.rb-c-page-content-box {
  #rb-ns-ui.page-content-box.set-mobile-mode-max-width(
    @_mobile-mode-max-width);
}

.rb-c-content-header {
  #rb-ns-ui.content-header.set-mobile-mode-max-width(@_mobile-mode-max-width);
}


a:link, a:visited {
  color: @link-color;
  text-decoration: none;
}

a:hover {
  color: darken(@link-color, 10%);
  text-decoration: underline;
}

h1 {
  font-size: 10pt;
}

h3 {
  margin-top: 2em;
}

img {
  border: 0;
}

pre, textarea, .CodeMirror, .editable.field-text-area {
  font-size: @textarea-font-size;
  font-family: @textarea-font-family;
  line-height: @textarea-line-height;
}

.editable.field-text-area {
  /*
   * Always show the text cursor when hovering over an editable text field
   * placeholder, so the entire thing feels like a text field.
   */
  cursor: text;
}

textarea {
  resize: none;
}


/**
 * Header actions.
 *
 * Structure:
 *     <div class="rb-c-actions" role="presentation">
 *      <menu class="rb-c-actions__content" role="menu">
 *       ...
 *      </menu>
 *     </div>
 */
#headerbar .rb-c-actions {
  float: right;

  /**
   * A header action.
   *
   * Structure:
   *     <li class="rb-c-actions__action" role="presentation">
   *      <a href="#" role="menuitem">...</a>
   *     </li>
   */
  &__action {
    border: 1px transparent solid;
    border-top: 0;
    box-sizing: border-box;
    display: inline-block;
    position: relative;

    a {
      color: inherit;
      display: block;
      font-size: 110%;
      margin: 0;
      padding: 0 1em;
      text-decoration: none;
      height: 32px;
      vertical-align: middle;
      line-height: 32px;
    }

		img {
      vertical-align: middle;
		}
  }

  &__content {
    box-sizing: border-box;
    list-style: none;
    margin: -@headerbar-padding 0;
    padding: 0;
    white-space: nowrap;
    z-index: @z-index-base;

    img {
      vertical-align: middle;
    }
  }

  .rb-c-menu {
    border: 1px #888 solid;
    border-radius: 0 0 @box-border-radius @box-border-radius;
    margin: 0;
    margin-right: -1px;
    right: 0;
  }

  .rb-c-menu__item {
    margin: 0;
    padding: 0;

    &:last-child {
      border-radius: 0 0 @box-border-radius @box-border-radius;
    }
  }

  #rb-ns-pages.base.on-shell-mobile-mode({
    display: none;
  });
}


/*
 * The "Loading..." indicator shown during AJAX operations.
 */
#activity-indicator {
  display: none;
  position: fixed;
  left: 50%;
  top: 0;
  text-align: center;
  font-weight: bold;
  background-color: #fce94f;
  border: 1px #c4a000 solid;
  border-top: 0;
  width: 8em;
  margin-left: -4em;
  padding: 0.5em 0.5em;
  z-index: @z-index-spinner;

  span {
    vertical-align: middle;
    line-height: 16px;
  }

  .fa-spinner {
    font-size: 16px;
  }

  &.error {
    background-color: #ffcd9c;
    width: 28em;
    margin-left: -14em;
    background-image: none;
    padding-left: 0.6em;

    a {
      margin-left: 1em;
      color: #0000CC;
      text-decoration: none;
    }
  }
}

#container {
  #rb-ns-pages.base.on-shell-mobile-mode({
    position: relative;
    transition: #rb-ns-ui.sidebars.mobile[@animation];
  });
}

#content_container {
  position: relative;
}

/*
 * The error information shown when an AJAX operation fails.
 */
#error {
  div {
    background: #ffcd9c;
    border: 1px #9a4306 solid;
    margin-bottom: 10px;
    padding: 8px 10px;
  }

  h1 {
    display: inline;
    margin: 0;
    padding: 0;
  }

  input[type='submit'] {
    margin-left: 10px;
  }
}


/*
 * The header bar at the top of the page. This contains the branding,
 * search field, and the accountnav element.
 *
 * This has the following children:
 *
 *    * #rbinfo
 *    * #accountnav
 *    * #search
 */
#headerbar {
  margin: 0;
  padding: @headerbar-padding;
  height: 22px;
  vertical-align: middle;
  z-index: @z-index-mobile-headerbar;

  br {
    clear: both;
    height: 0;
  }

  #logo {
    position: absolute;
    top: 3px;
    left: @headerbar-logo-padding-horiz;
    z-index: @z-index-logo;
  }

  #nav_toggle {
    @icon-size: 32px;
    @font-size: (@icon-size / 2);

    color: rgba(0, 0, 0, 0.8);
    cursor: pointer;
    display: none;
    font-size: @font-size;
    padding: ((@icon-size - @font-size) / 2);
    position: absolute;
    top: 0;
    left: 0;
    width: @icon-size;
    height: @icon-size;

    .fa {
      vertical-align: middle;
    }
  }

  #title {
    color: inherit;
    display: inline;
    font-weight: normal;
    font-size: 125%;
    margin: 0;
    padding: 0;
    vertical-align: middle;

    a {
      color: inherit;
      font-size: 120%;
      text-decoration: none;
    }

    .version {
      font-weight: normal;
      font-size: 90%;
    }
  }

  #search {
    float: right;
    margin: 0 1em;

    input {
      border: 1px #CCC solid;
      margin: 0;
      padding: 2px;
      border-radius: 6px;
      background-color: #EEEEEE;
      font-size: 1.2em;

      // Safari does super dumb things with input[type="search"]. Fix that.
      -webkit-appearance: textfield;
    }
  }

  #rb-ns-pages.base.on-shell-mobile-mode({
    border-bottom: 1px solid;
    height: auto;
    position: relative;
    text-align: center;
    transition: #rb-ns-ui.sidebars.mobile[@animation];

    #logo {
      position: relative;
      top: 0;
      height: 32px;
      width: 32px;
      z-index: @z-index-mobile-headerbar;
    }

    #nav_toggle {
      display: block;
    }

    #search {
      box-sizing: border-box;
      float: none;
      margin: 0.5em 0.5em 0 0.5em;

      input {
        /*
         * Style the search input to appear more like the saerch bars on
         * most mobile apps and sites, giving more breathing room.
         */
        background-color: white;
        box-sizing: border-box;
        padding: 4px 8px;
        margin: 0;
        width: 100%;
      }
    }

    #title {
      margin-left: 0.5em;

      .version {
        display: none;
      }
    }
  });
}


/*
 * The branding section of the headerbar, containing the logo and versioning
 * information.
 */
#rbinfo {
  float: left;
  position: absolute;
  left: 0;
  padding-top: 0.2em;
  padding-left: @headerbar-padding-left;

  #rb-ns-pages.base.on-shell-mobile-mode({
    /*
     * Reset positioning and floating so that on mobile, this will take the
     * full width of the page.
     */
    float: none;
    position: relative;
    padding: 0;
  });

  img {
    display: inline;
    vertical-align: middle;
  }
}

/*
 * An event mask overlaying the content of the page. It's shown only when
 * the mobile menu is shown. There is nothing visible, allowing the page
 * content to fully show through.
 */
#mobile_menu_mask {
  display: none;
  overflow: hidden;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: @z-index-nav-menu-mask;
}

/*
 * The container for the desktop navigation bar. This is not shown when in
 * mobile mode.
 */
#navbar-container {
  a {
    font-size: 110%;
    text-decoration: none;
  }

  /*
   * Alerts embedded in the navbar area should appear flush with the
   * navigation container.
   */
  .rb-c-alert {
    border-left: 0;
    border-right: 0;
    border-top: 0;
    border-radius: 0;
  }
}

/*
 * The navigation bar.
 *
 * This is the bar showing such items as "My Dashboard"< "New Review Request",
 * etc.
 */
#navbar {
  border-bottom: 1px solid;
  list-style: none;
  margin: 0;
  min-height: 1.5em;
  padding: @headerbar-padding;
  padding-left: @headerbar-padding-left;

  li {
    display: inline;
    height: 30px;
    margin: 0 1em 0 0;
  }

  .newreviewrequest {
    text-align: right;
  }

  #rb-ns-pages.base.on-shell-mobile-mode({
    display: none;
    padding-left: 10px;
    margin-top: 10px;

    li {
      display: block;
    }
  });
}

/*
 * The main container for the page's content.
 */
#page-container {
  padding: 0 @page-container-padding @page-container-padding
           @page-container-padding;

  #rb-ns-pages.base.on-shell-mobile-mode({
    position: relative;
    transition: #rb-ns-ui.sidebars.mobile[@animation];
  });
}

#read-only-banner {
  background: @read-only-banner-bg;
  border-bottom: @read-only-banner-border-bottom;
  font-size: 110%;
  padding: @headerbar-padding;
  padding-left: @read-only-banner-padding-left;
  vertical-align: middle;
}

#read-only-banner-header {
  display: inline;
  font-size: 100%;
  padding-right: @read-only-banner-header-padding-right;
}

#read-only-banner-message {
  vertical-align: middle;
}

#topbar {
  margin: 0 0 @page-container-padding 0;
}


/*
 * The box containing information on an AJAX error.
 */
.server-error-box .response-data {
  margin-top: 2em;
}


/****************************************************************************
 * Page themes
 ****************************************************************************/

/*
 * Default color scheme, used for the dashboard, My Account page, and others
 * featuring largely blue-ish colors.
 */
.page-colors(@topbar-bg: #rb-ns-ui.colors[@blue-80]);

/* Reviewable pages (review request, diff, file attachment, etc.) are brown. */
.reviewable-page {
  .page-colors(@topbar-bg: #rb-ns-ui.colors[@brown-80]);
}
